



Fig 1

|    | <u>Inst</u>           | <u>Hit/Miss</u> | <u>Data</u>                 |
|----|-----------------------|-----------------|-----------------------------|
| 18 | LDR [R <sub>m</sub> ] | Hit             | Data [R <sub>m</sub> ]      |
|    | MOV                   | N/A             | —                           |
|    | CMP                   | N/A             | —                           |
|    | :                     | :               | :                           |
| 20 | LDR [R <sub>m</sub> ] | Miss            | —                           |
|    | MOV                   | N/A             | —                           |
|    | CMP                   | N/A             | Data [R <sub>m</sub> ]      |
|    | :                     |                 |                             |
| 22 | LDR [R <sub>1</sub> ] | Miss            | —                           |
| 24 | LDR [R <sub>2</sub> ] | Miss            | —                           |
|    | MOV                   | N/A             | —                           |
|    | CMP                   | N/A             | 28 — Data [R <sub>2</sub> ] |
|    | ADD                   | N/A             | 26 — Data [R <sub>1</sub> ] |

↓ variable delay

missed data returned out of order

Fig. 2



Fig. 3



Fig. 4

Instruction Trace Stream

62 (LDR [R1] --- miss)  
 (MOV)  
 SUB  
 ↓  
 earliest trace info.  
 60 SYNC {1 pending}  
 LDR [R2] --- miss  
 CMP  
 ADD  
 64 LDR [R3] --- hit  
 MOV  
 SUB  
 CMP  
 :

Data Trace Stream

(Data Place Holder)  
 —  
 —  
 66 Data Place Holder  
 LateData [R1]  
 68 —  
 Data [R3]  
 LateData [R2]  
 70 —  
 —  
 :

Fig. 5



Fig. 6



Fig. 7

| Exact Match | Add Match | Data Match | Trace Activation Point |
|-------------|-----------|------------|------------------------|
| ✓           | ✓         | ✓          | ①                      |
| ✓           | ✓         | ✗          | none                   |
| ✗           | ✓         | ✓          | ②                      |
| ✗           | ✓         | ✗          | ②                      |

Fig. 8



LSM  $R_n[\text{Add}], \text{Reg List}$

16 bits

0000010001000010111

⇓

|     |  |  |  |  |  |  |
|-----|--|--|--|--|--|--|
| R0  |  |  |  |  |  |  |
| R1  |  |  |  |  |  |  |
| R2  |  |  |  |  |  |  |
| R3  |  |  |  |  |  |  |
| R7  |  |  |  |  |  |  |
| R11 |  |  |  |  |  |  |



Fig. 10





Fig. 12



Fig. 13